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REPROGRAMMABLE FIELD DEVICE IN A DISTRIBUTED PROCESS CONTROL 

SYSTEM 



FIELD OF THE INVENTION 
The present invention relates generally to process control systems and, more 
5 particularly, to a system wherein field devices are reprogrammed with software 
downloaded via the system's standard communication protocol. 

PESCftlFTION OF THE RELATED ART 
Distributed process control systems, like those used in chemical, petroleum or 
other processes, typically include one or more process controllers communicatively 
10 coupled to one or more field devices via analog, digital or combined analog/digital 
buses. The field devices, which may be, for example, valves, valve positioners, 
switches and transmitters (e.g., temperature, pressure and flow rate sensors), are 
located within the process environment and perform process functions such as 
opening or closing valves, measuring process parameters, etc. Smart field devices, 
15 such as the field devices conforming to the well-known Fieldbus protocol may also 

perform control calculations, alarming functions, and other control functions typically 
implemented within the controller. The process controllers, which are also typically 
located within the plant environment, receive signals indicative of process 
measurements made by the field devices and/or other information pertaining to the 
20 field devices and execute a controller application that runs, for example, different 

control modules which make process control decisions, generate control signals based 
on the received information and coordinate with the control modules or blocks being 
performed in the field devices, such as Fieldbus field devices. The control modules in 
the controller send the control signals over the communication lines to the field 
25 devices to thereby control the operation of the process. 

Information from the field devices and the controller is usually made available 
over a data highway, or bus, to one or more other hardware devices, such as operator 
workstations, personal computers, data historians, report generators, centralized 
databases, etc, typically placed in control rooms or other locations away from the 
30 harsher plant environment. These hardware devices run applications that may, for 

example, enable an operator to perform functions with respect to the process, such as 
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changing settings of the process control routine, modifying the operation of the 
control modules within the controller or the field devices, viewing the current state of 
the process, simulating the operation of the process for the purpose of training 
personnel or testing the process control software, keeping and updating a 

5 configuration database, etc. 

The process control industry has developed a number of standard, open 
communication protocols including, for example, the FOUNDATION™ Fieldbus, 
HART®, PROFIBUS®, WORLDFIP®, LONWORKS®, Device-Net®, and CAN 
protocols, which enable field devices made by different manufacturers to be used 

10 together within the same process control network. In fact, any field device that 

conforms to one of these protocols can be used within a process to communicate with 
and to be controlled by a controller that supports the protocol, even if that field device 
is made by a different manufacturer than the manufacturer of the DCS controller. The 
communication protocols enable the controllers and field devices to transmit and 

15 receive process control information and non-process control information, such as 
alarm messages, trend data, set point changes, etc. 

For example, the FOUNDATION™ Fieldbus protocol promulgated by the 
Fieldbus Foundation is an all-digital, two-wire bus protocol that allows devices to 
interoperate and communicate with one another via a standard bus in a process control 

20 network. In order to implement a control strategy in the process control network, the 
operation of the field devices and the exchange of process control information must be 
precisely scheduled so that proper data is provided to each field device before the 
information is needed. At the same time, field devices and controllers must be able to 
communicate non-process control information over the network without affecting the 

25 execution of process control by the network. The Fieldbus protocol facilitates the 
transmission of both types of information by providing for both scheduled 
(synchronous) and unscheduled (asynchronous) communications. 

A communication schedule for the process control network contains the times 
that each control module of each device is scheduled to start periodic communication 

30 activity on the bus and the length of time for which the communication activity is to 
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occur. In general, communication activities over the bus are divided into repeating 
macrocycles, each of which includes one synchronous communication for each 
control module active on any particular segment of the bus and one or more 
asynchronous communications for one or more of the control modules or devices 
5 active on a segment of the bus. 

During each macrocycle, each of the control modules active on a particular 
segment of the bus executes, usually at a different, but precisely scheduled 
(synchronous) time and, at another precisely scheduled time, publishes its output data 
on that segment of the bus in response to a compel data command generated by a 
10 scheduling device that stores and controls execution of the process schedule. 

Preferably, each control module is scheduled to publish its output data shortly after 
the end of the execution period of the control module. Furthermore, the data 
publishing times of the different control modules are scheduled serially so that no two 
control modules on a particular segment of the bus publish data at the same time. 
15 During the time that synchronous communication is not occurring, each field device is 
allowed, in turn, to transmit non-process control information as well as additional 
process control data in an asynchronous manner using token driven communications. 
The execution times and the amount of time necessary to complete execution of each 
control module are stored in the device in which the control module resides while, as 
20 noted above, the times for sending the compel data commands to each of the devices 
on a segment of the bus are stored in the scheduling device for that segment. 

To effect communications during each macrocycle, the scheduling device of 
the bus segment sends a compel data command to each of the devices on the bus 
segment according to the list of transmit times stored in the scheduling device. Upon 
25 receiving a compel data command, a control module of a device publishes its output 
data on the bus for a specific amount of time. After the scheduling device has sent a 
compel data command to each of the control modules on a particular segment of the 
bus and during the times that control modules are executing, the scheduling device 
may cause asynchronous communication activities to occur. To effect asynchronous 
30 communication, the scheduling device sends a pass token message to a particular field 
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device. When a field device receives a pass token message, that field device has full 
access to the bus (or a segment thereof) and can send asynchronous messages until the 
messages are complete or until a maximum allotted "token hold time" has expired. 
Thereafter the field device releases the bus (or any particular segment thereof) and the 
5 scheduling device sends a pass token message to another device. This process repeats 
until the end of the macrocycle or until the scheduling device is scheduled to send a 
compel data command to effect synchronous communication. Of course, depending 
on the amount of message traffic and the number of devices and control modules 
coupled to any particular segment of the bus, not every device may receive a pass 

10 token message during each macrocycle. 

Another example of a standard communication protocol, the HART protocol, 
uses twisted pair wiring with combined analog/digital capabilities to allow 
communications between field devices in a process control network. Under the 
HART protocol, process control information is transmitted using a 4-20mA analog 

15 signal, with the magnitude of the signal being indicative of the value of the process 
control variable being transmitted. The HART protocol also provides a digital signal 
superimposed over the analog signal that may be used to communicate both process 
control and non-process control information. Digital communications in the HART 
protocol are unscheduled (similar to Fieldbus asynchronous communications), bi- 

20 directional, and primarily implemented through master/slave communications. The 
master device issues commands in request/response format to the slave device. The 
slave responds to the request by transmitting the requested information back to the 
master to complete the exchange. Alternatively, the slave can operate in burst mode, 
wherein the slave sends out packets of information in a known format as a broadcast 

25 message that is detected and received by the host device. Although the HART 
protocol is implemented in a process control network with a different physical 
configuration than the Fieldbus protocol, the HART protocol, like the Fieldbus and 
other communications protocols, allows transmission of non-process control 
information without affecting the network's ability to perform process control. 
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Each field device is programmed with software or firmware that controls the 
operation of the device and that implements one or more process control modules. 
The first generation of electronic process control instruments and field devices were 
programmed with ROM-based software or some other non-reprogrammable memory. 
5 The devices functioned satisfactorily for their original intended purpose, but it was 
difficult or impossible to reprogram the devices to, for example, correct a software 
problem or defect, introduce new functionality for the device, improve the 
performance of the device, etc. If one of these devices required reprogramming, the 
electronics module was removed and replaced by a new module programmed with the 
10 repaired or upgraded software. In some cases, the electronics module was not 
replaceable and the field device had to be replaced with a different device that 
implemented the corrected software or additional functionality. In either case, the 
process was interrupted while the field device was updated. 

Subsequent generations of process control instruments have evolved from 
15 ROM-based software to reprogrammable devices. The evolution of the 

reprogrammable devices has been facilitated by improvements in non-volatile 
memory (NVM). In one implementation of a reprogrammable device, the electronics 
module of the device is removed, the NVM is reprogrammed with the corrected or 
updated firmware, and reinstalled in the device. This implementation eliminates the 
20 need for a new electronics module each time the firmware is changed, but the person 
reprogramming the NVM is still required to go to the location of the device to 
perform the firmware upgrade. Moreover, as with the first generation devices, at a 
minimum, some or all process control functions are suspended while the device is 
reprogrammed. In extreme cases, the entire process must be shut down. 
25 In another implementation of a reprogrammable device, the electronics module 

is not removed from the device, but reprogramming of the device is effected by 
attaching a downloading device to a communications port of the field device. In this 
way, code is downloaded to the field device without disassembling the device. 
However, this implementation of a reprogrammable device does not eliminate the 
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need to send a person out to the location of the field device to reprogram the device or 
of suspending process control while the code is downloaded. 

Yet another implementation of a reprogrammable device facilitates 
downloading code remotely from a host device of the process control system. In this 

5 implementation, the code is transmitted to the device over the data highway or bus of 
the process control system. The download is initiated at the host device in the control 
room, and the host device transmits the code over the bus. Currently, the host device 
performs the download using either a standard communication protocol for the 
process control system which allows other devices to operate, or a non-standard 

10 communication protocol that is recognized by the host and the device but not 

necessarily by the other devices connected to the bus. Regardless of the protocol used 
to communicate the code, the host takes control of the bus, thereby preventing 
communications between the other devices connected to the bus during the download. 
This implementation is an improvement over the other implementations because it 

15 eliminates the need to send a person to the location of the device, but the host device 
usurps control of the bus for the duration of the download. Consequently, as with the 
other implementations, the process control system is partially or completely taken out 
of service while the code is downloaded to the field device. 

These examples illustrate reprogrammable devices developed by the process 

20 control industry that eliminate the necessity of changing the hardware of the devices 
or going to the physical location of the device to perform software and/or firmware 
downloads. However, despite the devices' ability to be reprogrammed, the presently 
known methods for reprograrnming the devices require taking the process control 
system partially or completely out of service for the duration of the downloading and 

25 reprograrnming the devices, a process that may require as much as a half of a day 

interruption of service to reprogram a single field device. This results in the reduction 
of the output of the controlled process caused by the periods of suspended operations 
and increased labor cost (where manual reprograrnming of the field devices is 
required). 
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SUMMARY OF THE INVENTION 
The present invention is directed to a method of reprogramming a field device 
in a process control network using the standard communications protocol for the 
network, and a reprogrammable field device in the process control network adapted 
5 for being reprogrammed using the standard communications protocol for the network. 
The method and device of the present invention use the standard communications 
protocol to transmit the downloaded code to the field device and store the downloaded 
code in the field device while the device is enabled to perform process control. Once 
the new code is downloaded and stored in the field device, the field device is disabled 
10 from performing process control, reprogrammed to execute the downloaded code, and 
reenabled to perform process control. 

By using the standard communications protocol for the process control 
network during the regular operation of the network, the new code is downloaded to 
the reprogrammable field device without interrupting the performance of process 
15 control by either the reprogrammable field device or the other devices in the network, 
thereby reducing the amount of time the process control network is placed out of 
service while the field device is reprogrammed. Although the field device must be 
taken out of service to be reprogrammed to execute the downloaded code, the amount 
of time the field device is out of service for reprogramming, in most instances, is 
20 substantially less than the time required to download the code over the network. 
Consequently, the extent of the disruption to the process control network due to 
reprogramming the field device is significantly reduced compared to previous 
methods and devices that required suspending process control during both the 
downloading of code and the reprogramming of the field device. Moreover, by using 
25 the standard communication protocol of the process control network, the amount of 
additional coding required to implement the method and device of the present 
invention is greatly reduced because the functionality for communicating messages, 
error checking, and the like are already present in the standard communications 
protocols. 
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According to one aspect of the present invention, a method of reprogramrning 
a field device in a process control network having a plurality of devices 
communicatively linked on a bus includes the steps of downloading the program 
instructions from a host device to the field device using the standard communication 
5 protocol used in the process control network while the field device performs process 
control, storing the downloadable program instructions in the field device, and 
causing the field device to execute the downloadable program instructions. The 
standard communication protocol may provide both scheduled and unscheduled 
communications, such as the communications supported by the Fieldbus protocol, 

10 with the host device transmitting the downloadable program instructions via one or 
more unscheduled queued communications. Moreover, the standard communication 
protocol may provide for analog and digital communications, such as the 
communications supported by the HART protocol, with the host device transmitting 
the downloadable program instructions via one or more digital communications. 

15 Additionally, the downloadable program instructions may be divided into data packets 
that are transmitted by the host device over time and reassembled by the field device. 

In one embodiment of the method according to the present invention, the field 
device has a first memory and a second memory, with the downloadable program 
instructions being stored in the second memory while the field device is capable of 

20 executing stored program instructions in the first memory. According to one 

embodiment, the field device is reprogrammed by copying the downloadable program 
instructions from the second memory to the first memory, and subsequently executing 
the downloadable program instructions in the first memory. In another embodiment, 
the field device ceases executing the stored program instructions in the first memory 

25 and is redirected to execute the downloadable program instructions in the second 
memory. 

According to another aspect of the present invention, a system for 
reprogramrning field devices is provided in a process control network having a 
plurality of devices communicatively linked over a bus, wherein each of the devices is 
30 capable of performing a process function and of communicating on the bus using a 
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standard communications protocol. The system includes a first device that generates 
input signals including downloadable program instructions and a second device 
capable of receiving the input signals transmitted over the bus. The second device 
includes a processor adapted to execute program instructions stored in the second 
5 device, a first memory adapted to store program instructions that may be executed by 
the processor, and a second memory adapted to store the downloadable program 
instructions received in the input signals. The first device transmits the input signals 
to the second device over the bus and the second device receives the input signals and 
stores the downloadable program instructions in either the first or the second memory. 

10 The second device stores the downloadable program instructions while the processor 
is enabled to execute stored program instructions to perform process control. The 
standard communications protocol may include scheduled and unscheduled 
communications, with the first device transmitting the input signals using 
unscheduled queued communications. Alternatively, the standard communication 

15 protocol may include analog and digital communications, with the first device 
transmitting the input signals using digital communications. 

The features and advantages of the invention will be apparent to those of 
ordinary skill in the art in view of the detailed description of the preferred 
embodiment, which is made with reference to the drawings, a brief description of 

20 which is provided below. 

BRIEF DESCRIPTION OF THE DRAWINGS 
Fig. 1 is a block diagram of a typical process control network having different 
process control functions performed by different hardware devices and capable of 
downloading code to the field devices; and 

25 Fig. 2 is a block diagram of a reprogrammable field device capable of being 

reprograrnmed using the standard communications protocol in a distributed process 
control system like that of Fig. 1. 
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DESCRIPTION OF THE PREFERRED FMBODTMENTS 
Referring now to Fig. 1, a distributed process control system 10 includes one 
or more dedicated process controllers 12 each connected to one or more field devices 
14 and 15 via input/output (I/O) modules 16 which may be, for example, Fieldbus or 
5 HART interfaces. The controllers 12 are also coupled to one or more host or operator 
workstations 1 8 via a data highway 20 which may be, for example, an Ethernet link. 
While the controllers 12, I/O modules 16 and field devices 14 and 15 are located 
down within and distributed throughout the harsh plant environment, the operator 
workstations 1 8 are usually located in control rooms or other less harsh environments 

10 easily assessable by controller personnel. Each of the controllers 12, which may be by 
way of example, the DeltaV controller sold by Fisher-Rosemount Systems, Inc., stores 
and executes a controller application 23 that implements a control strategy using a 
number of different, independently executed, control modules 24. The control 
modules 24 may each be made up of what are commonly referred to as function 

15 blocks wherein each function block is a part or a subroutine of an overall control 

routine and operates in conjunction with other function blocks (via communications 
called links) to implement process control loops within the process control system 10. 
As is well known, function blocks typically perform one of an input function, such as 
that associated with a transmitter, a sensor or other process parameter measurement 

20 device, a control function, such as that associated with a control routine that performs 
PID, fuzzy logic, etc. control, or an output function which controls the operation of 
some device, such as a valve, to perform some physical function within the process 
control system 10. Of course hybrid and other types of function blocks exist. 
However, the control modules 24 could be designed using any desired control 

25 programming scheme including, for example, sequential function block, ladder logic, 
etc. and are not limited to being designed using function block or any other particular 
programming technique. 

In the system illustrated in Fig. 1, the field devices 15 connected to one of the 
controllers 12 are smart field devices, such as Fieldbus field devices, which include a 

30 processor and a memory. These devices store and execute the controller application 
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23 as well as modules 24, or sub-parts, such as function blocks, of one or more of the 
modules 24. The modules or parts of modules within the field devices 1 5 may be 
executed in conjunction with the execution of the modules within the controller 12 to 
implement process control as is known. Similarly, one or more of the field devices 14 
5 connected to another controller 12 may also be smart field devices, such as HART 
field devices, with controller application 23 and control modules 24 executed to 
implement process control. 

The host workstation 18 stores and executes a configuration application 25 
that is used to create or change the process control modules 24 and to download these 
10 control modules via the data highway 20 to one of the controllers 1 2 and/or to field 
devices such as one of the field devices 15. The host workstation 18 may also store 
and execute a viewing application 26 that receives data from the controller 12 via the 
data highway 20 and that displays this information via a display mechanism using 
predefined user interfaces 27 or views, typically created using the configuration 
15 application 25. In some cases, the viewing application 26 receives inputs, such as set 
point changes, from the user and provides these inputs to the controller application 23 
within one or more of the controllers 12. 

A data historian 28 is connected to the data highway 20 and stores data in a 
memory therein using any desired or known data historian software. However, the 
20 data historian could alternatively be in one or more of the workstations 1 8 if so 
desired. Furthermore, a configuration database 30 runs a configuration database 
application 32 that stores the current configuration of the process control system and 
data associated therewith. 

Referring now to Fig. 2, a reprogrammable field device 40 is a smart device 
25 having a CPU 42, a first memory 44, a second memory 46, and a transfer unit 48. The 
reprogrammable field device 40 is typically connected to a controller 12 via an 
input/output device 16, and one or all of the field devices 14, 15 of Fig. 1 may be 
reprogrammable field devices 40. The reprogrammable field devices 40 are also 
capable of communicating with other devices connected over a bus or other 
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communication link using the standard communications protocol (such as the HART 
or Fieldbus protocol) used by that bus or other communication link. 

In the embodiment of Fig. 2, the reprogrammable field device 40 stores the 
control application 23 and the control modules 24 in the first memory 44, and may 
5 also store the operating system software 50 for the reprogrammable field device 40, 
and any other software for the reprogrammable field device 40 that is intended to be 
reprogrammable. Other types of data, such as calibration data 52, could be stored in 
the first memory 44 or in some other memory location or memory device where the 
data will not be corrupted by a code download. During normal operation of the 

10 reprogrammable field device 40, the CPU 42 executes the code stored in the first 

memory 44 to operate the reprogrammable field device 40 and to perform the process 
control functions required by the process control system 10. 

The second memory 46 of the reprogrammable field device 40 stores newly 
downloaded code that is used to reprogram the reprogrammable field device 40. 

15 When the reprogrammable field device 40 receives the input message over the data 
highway 20 containing the downloadable code, the CPU 42 writes the downloadable 
code into the second memory 46. The downloadable code may be received and stored 
in the second memory 46 while the reprogrammable field device 40 is operational and 
the CPU 42 is capable of concurrently executing code stored in the first memory 44 to 

20 perform process control. Once the code is completely downloaded into the second 
memory 46, the reprogrammable field device 40 is taken out of service or is set to 
some other non-operational state for a relatively short period of time while the 
reprogrammable field device 40 is reprogrammed to execute the downloaded code. 
The process of storing newly downloaded code and reprogramming the 

25 reprogrammable field device 40 is controlled by the transfer unit 48. The transfer unit 
48 may be implemented as part of the CPU42, as a separate CPU on its own, or as 
separate logic executed by the CPU 42 to control the code storage and reprogramming 
of the reprogrammable field device 40. When the reprogrammable field device 40 
receives the input messages with the downloaded code, the transfer unit 48 causes the 

30 CPU 42 to write the downloaded code to proper location in either the first memory 44 
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or second memory 46 as will be described more fully below. Once the downloaded 
code is stored, the transfer unit 48 may cause the reprogrammable field device 40 to 
go out of service or set the device 40 to some other non-operational state while the 
device is reprogrammed. Moreover, the transfer unit 48 controls the reprogramming 
5 of the device 40 by causing the CPU 42 to execute the downloaded code, and the 

resumption of normal process control operations by the reprogrammable field device 
40.. 

Although the first memory 44 and the second memory 46 are illustrated in 
separate blocks in Fig. 2, the first and second memories 44, 46, respectively, are not 

10 constrained to a particular physical or operational relationship, or to being 

implemented by a particular type of storage device. For example, in one embodiment 
of a reprogrammable field device 40, the first memory 44 is a reprogrammable NVM 
storage device, such as flash memory, and the second memory 46 is a temporary 
memory storage device, such as classical RAM or other type of RAM, or a different 

15 type of NVM storage device man the NVM of the first memory 44. When the new 
code is downloaded over the data highway 20, the transfer unit 48 causes the 
temporary storage of the downloaded code in the second memory 46. Once the 
download is complete, the transfer unit 48 takes the reprogrammable field device 40 
out of service and causes the transfer of the downloaded code from the second 

20 memory 46 into the proper location in the flash memory of the first memory 44. For 
example, if the downloaded code contains a new or repaired operating system for the 
reprogrammable field device 40, the downloaded code is written to the NVM of the 
first memory 44 at the storage location for the operating system 50. Moreover, if the 
downloaded code includes additional functionality for the reprogrammable field 

25 device 40 in the form of a new control module 24, the downloaded code for the new 
control module 24 may be written to a vacant storage location in the NVM of the first 
memory 44 while the code for the control application 26 is updated with any 
additional functionality and with the address for the new control module 24. Once the 
downloaded code in the second memory 46 is written into the NVM of the first 

30 memory 44, the transfer unit 48 returns the reprogrammable field device 40 to its 
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normal operational mode with the CPU 42 executing the new downloaded code now 
stored in the first memory 44. 

In another embodiment of the reprogrammable field device 40, the 
reprogrammable field device 40 is capable of executing code stored in either the first 
5 memory 44 or the second memory 46. For example, both the first memory 44 and the 
second memory 46 could be NVM storage devices, with both storage devices having 
the capacity to store the same reprogrammable code. Consequently, the second 
memory 46 would be able to store control applications 23, control modules 24, 
operating system software 50, and any other information stored in the first memory 

10 44. In this embodiment, the transfer unit 48 includes a pointer or storage for an 

address that indicates to the CPU 42 which memory 44, 46 to access for execution of 
the reprogrammable code. 

Applying this embodiment to the reprogrammable field device 40 of Fig. 2, 
the pointer in the transfer unit 48 is initially set to direct the CPU 42 to execute the 

15 code stored in the NVM of the first memory 44 while the NVM of the second memory 
46 sits idle. When code for reprogramming the reprogrammable field device 40 is 
transmitted over the data highway 20 to the reprogrammable field device 40, the 
transfer unit 48 causes the CPU 42 to write the downloadable code into the NVM of 
the second memory 46. The downloaded code updates or replaces the code previously 

20 stored in the NVM of the second memory 46. After the code download is complete, 
the transfer unit 48 takes the reprogrammable field device 40 out of service and 
updates the pointer to cause the CPU 42 to execute the downloaded code currently 
stored in the NVM of the second memory 46, thereby reprograrnrning the device 40. 
After the pointer is updated, the reprogrammable field device 40 can be placed back in 

25 service for normal operation according to the newly downloaded code in the NVM of 
the second memory 46. Once the reprogrammable field device 40 is reprogrammed to 
execute the downloaded code in the second memory 46, the next instance of 
downloading code will result in storing the downloaded code in the NVM of the first 
memory 44 and subsequently reprogramming the CPU 42 to execute the downloaded 

30 code in the first memory 44. In this embodiment of the reprogrammable field device 
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40, it may also be necessary to copy the current version of the downloaded code from 
the executing memory to the idle memory to ensure that the latest version of the 
reprogrammable field device 40's software is updated by subsequent code downloads. 
The copying can occur either during the reprogramming cycle or, to reduce the 
disruption to the process control system 10, during a period when the reprogrammable 
field device 40 is operational but not performing process control, or could be 
performed live as a background task since the software is being run out of a separate 
memory. 

In yet another embodiment, the reprogrammable field device 40 has a single 
NVM storage device with read/write capability. The NVM storage device is 
partitioned to create the first memory 44 and the second memory 46. As in the 
previously described embodiment, a pointer in the transfer unit 48 directs the CPU 42 
to execute the downloaded code in the partition containing the current version of code 
for the reprogrammable field device 40. When new code is downloaded to the 
reprogrammable field device 40, the downloaded code is written into the idle partition 
of the NVM storage device and, when the download is complete, the reprogrammable 
field device 40 is reprogrammed to execute the newly downloaded code in the 
previously idle partition of the NVM storage device. 

The operations of downloading code and reprogramming the reprogrammable 
field device 40 are effected using the standard communications protocol of the process 
control system 10 and may be completed while the reprogrammable field device 40 is 
operational within a process control network with only minimal affect on the 
execution of the process control network. The download is initiated by a host 1 8 into 
which the new code has been loaded. Prior to the actual download of the code, the 
host 1 8 may transmit a message to a controller 12 which then transmits a message to 
the reprogrammable field device 40 that instructs the reprogrammable field device 40 
that the host 1 8 (or controller 1 2) is going to download code to the reprogrammable 
field device 40. The initial message from the host 1 8 may contain information 
pertaining to the type of code being downloaded (operating system, control 
applications, control modules, etc.), the version of the code being downloaded, the 
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amount of storage space required for the downloaded code, and the like. Upon 
receiving the initial message from the host 1 8, the reprogrammable field device 40 
prepares to receive the downloaded code in one or more subsequent messages from 
the host 1 8, and responds to the host 1 8 with a message indicating that it is prepared 
5 to receive the code. The response message from the reprogrammable field device 40 
may include additional information for the host 18 such as storage constraints, the 
version of the software currently running in the reprogrammable field device 40, and 
the like. 

Once the host 18 receives the response from the reprogrammable field device 

10 40, the host 1 8 can begin downloading the code to the reprogrammable field device 
40. The code is transmitted to the reprogrammable field device 40 over the data 
highway 20 and then over a protocol bus or link (such as those associated with the 
HART or Fieldbus protocols) using the standard communications protocol for the 
process control system 10. Depending on the volume of code to be downloaded, the 

15 transfer may require either a single transmission from the host 1 8, or the transmission 
of multiple packets of data. The number of transmissions required will also depend 
on the speed of the data highway 20 and the protocol communication link, the amount 
of time allotted to the controller 12 in the process control schedule for transmitting 
data, the speed with which the storage device in the reprogrammable field device 40 

20 can parse and store the data, etc. As the reprogrammable field device 40 receives each 
of the download transmissions from the host 1 8 (or controller 12), the data is 
reassembled in the storage device for proper execution by the CPU 42 of the 
reprogrammable field device 40. As the transmissions are received by the 
reprogrammable field device 40, the standard transmission verification of the 

25 communications protocol, such as checksums, is used to ensure that each transmission 
is received properly by the reprogrammable field device 40. 

As the new code is downloaded from the host 18, the reprogrammable field 
device 40 stores the downloaded code in either volatile or non-volatile memory in a 
manner as previously described or in some manner as required by the storage device. 

30 It is important to note at this point that the use of the standard communications 
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protocol allows the reprogrammable field device 40 to remain operational during the 
downloading and storage of the new code. For example, in the Fieldbus protocol, the 
new code is downloaded using asynchronous communications when the I/O device 
associated with the controller 12 and the reprogrammable field device 40 receive their 
5 pass token messages. Concurrently, the control modules 24 of the reprogrammable 
field device 40 and of the other field devices 14, 15, 40 are operating within their 
control loops to perform process control and transmit process control information 
according to the synchronous schedule. Similarly, in networks implementing the 
HART protocol, the downloaded code is transmitted over the twisted pair wiring in 
10 the digital overlay while the process control information is communicated by the 
analog signal. Consequently, process control is unaffected by the downloading of 
code to the reprogrammable field device 40. Moreover, by using the data highway 20 
and the appropriate protocol bus or link to download the new code, the 
reprogrammable field device 40 is reprogrammed without sending a person to the 
15 physical location of the reprogrammable field device 40. 

By using the standard communications protocol, the host 1 8 (or controller 12) 
can download code to multiple reprogrammable field devices 40 without interrupting 
the operation of the system 1 0 so that the devices 40 can be reprogrammed 
simultaneously during a single period in which process control is interrupted. For 
20 example, in the Fieldbus protocol, a controller's associated I/O device can either 
transmit broadcast messages to all the devices 40 being reprogrammed, or publish 
messages to the individual devices 40 over a period of multiple macrocycles. In the 
HART protocol, each reprogrammable field device 40 has a dedicated connection 
such that code may be simultaneously downloaded by the controller 12 to multiple 
25 devices 40. After all the devices 40 have received and stored the downloaded code 
from the host 18 or controller 12, the reprogramming cycle for the devices 40 can be 
initiated in a manner more fully described below during a single period in which 
process control is interrupted. 

Once the download and storage of the new code is complete, the 
30 reprogrammable field device 40 is ready to be reprogrammed to execute the 
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downloaded code. At this point, the host 18 verifies that the reprogrammable field 
device 40 is ready for the reprogramming cycle. The verification may include 
transmitting an instruction to the reprogrammable field device 40 to compute a 
checksum on the downloaded data to verify that the data received by the 
5 reprogrammable field device 40 matches the data transmitted by the host 18. If the 
verification operation indicates that the download was unsuccessful, the host 1 8 may 
reinitiate the download sequence, issue a notification to the operator that the 
download was unsuccessful, or perform some other preprogrammed error handling 
function. 

10 If the download was successful, the host 1 8 issues a command, in either the 

initial verification message or a subsequent message, for the reprogrammable field 
device 40 to prepare for reprogramming. Depending on the requirements of the 
particular reprogrammable field device 40, the operational mode of the 
reprogrammable field device 40 during the reprogramming cycle will vary. For 

15 example, a controlling instrument such as a valve positioner may require being taken 
out of service completely while the device is reprogrammed. While the valve 
positioner is out of service, it may be necessary for the host 1 8 or controller 12 to 
notify other field devices 14, 15, 40 and control modules 24 that the valve positioner 
is out of service. The notification by the host 18 or controller 12 may also include 

20 instructions to change the operational state of one or more of the field devices 14, 15, 
40 or control modules 24 while the valve positioner or other reprogrammable field 
device 40 is reprogrammed. For other reprogrammable field devices 40, such as 
transmitters, the host 1 8 may instruct the reprogrammable field device 40 to operate at 
a steady state and to transmit process control information with a constant value, such 

25 as a steady flow rate, while the reprogrammable field device 40 is reprogrammed. In 
other cases, the host 1 8/controller 12 may override the process control loop in place of 
the reprogrammable field device 40 during the reprogramming cycle and 
communicate directly with the other devices 14, 15, 40 and control modules 24 in the 
control loop to allow them to operate under semi-normal operating conditions. The 

30 host 1 8/controller 12, reprogrammable field device 40, other field devices 14, 15, 40 
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and the control modules 24 may be required to operate under other types of modified 
operating modes depending on the particular requirements of the field devices 14, 15, 
40, control loops and process control system 1 0. 

Once the reprogrammable field device 40 and the process control system 1 0 
are prepared by the host 1 8/controller 12, the host 1 8/controller 12 transmits a 
message to the reprogrammable field device 40 with an instruction for the 
reprogrammable field device 40 to begin reprogramming itself. The reprogrammable 
field device 40 may reprogram itself via one of the reprogramming methods 
previously described, such as by copying the downloaded code from the second 
memory 46 to the first memory 44 or changing the pointer in the transfer unit 48 to 
cause the CPU 42 to execute the downloaded code in the previously idle memory, or 
by any other method that is dictated by the hardware configuration of the 
reprogrammable field device 40. After the reprogrammable field device 40 is 
reprogrammed, communications between the host 1 8/controller 12 and the 
reprogrammable field device 40 must be reestablished so the reprogrammable field 
device 40 can return to its normal operational mode for implementation of process 
control. Communications may be reestablished by a response message from the 
reprogrammable field device 40 to the host 1 8/controller 12 after the device 40 is 
successfully reprogrammed, or by the host 1 8/controller 12 transmitting a restart 
message to the reprogrammable field device 40 after a predetermined period of time. 

The method and device of the present invention as described herein facilitate 
downloading code to the reprogrammable field devices 40 over the network without 
affecting the process control performed by the process control system 10. The method 
and device constitute a significant enhancement over previously known methods of 
downloading code to field devices wherein no process control could be performed for 
the duration of downloading the code and reprogramming the field device. For 
example, in a process control system using the HART protocol, 15 minutes is required 
to download 30Kb of data to a previously known field device and 15 seconds is 
required to reprogram the device, resulting in about a 16 minute interruption in 
process control. Using the method and device according to the present invention, the 
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30Kb data is downloaded to the reprogrammable field device 40 in the digital overlay 
while process control information is simultaneously transmitted in the analog signal, 
and process control is interrupted for less than one minute when the device 40 is 
reprogrammed. Moreover, the field device does not need to be physically 
5 manipulated to reprogram, i.e., no trip to the instrument, no opening the instrument, 
etc., thereby reducing the labor costs associated with reprogramming field devices and 
the cost of lost network operating time caused by taking the control loops out of 
service. 

In addition to reducing the impact on the process control, implementation of 

10 the method and device according to the present invention is simplified by using the 

standard communications protocol already existing in the process control system. The 
method can be used in any protocol the supports writing blocks of data in some 
format. Consequently, no additional coding is required for functions such as 
communicating the code, error checking, and the like that are already executed by the 

15 communications protocol. 

When implemented, any of the software or firmware described herein may be 
stored in any computer readable memory such as on a magnetic disk, a laser disk, or 
other storage medium, in a RAM or ROM of a computer or processor, etc. Likewise, 
the software may be delivered to a user, a process control system, or the host 1 8 via 

20 any known or desired delivery method including, for example, on a computer readable 
disk or other transportable computer storage mechanism or over a communication 
channel such as a telephone line, the Internet, the World Wide Web, any other local 
area network or wide area network, etc. (which delivery is viewed as being the same 
as or interchangeable with providing such software or firmware via a transportable 

25 storage medium). Furthermore, the software or firmware may be provided directly 

without modulation or may be modulated using any suitable modulation carrier wave 
before being transmitted over a communication channel. 

Thus, while the present invention has been described with reference to specific 
examples, which are intended to be illustrative only and not to be limiting of the 

30 invention, it will be apparent to those of ordinary skill in the art that changes, 
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additions or deletions may be made to the disclosed embodiments without departing 
from the spirit and scope of the invention. 
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What is claimed is: 

1 . A method of reprogramming a field device in a process control 

2 network having a plurality of devices which are communicatively linked on a bus and 

which use a standard communication protocol to perform process control functions, 
4 the method comprising the steps of: 

downloading program instructions from a host device to one of the 
6 field devices using the standard communication protocol; 

storing the downloaded program instructions in the field device; and 
8 causing the field device to execute the downloaded program 

instructions. 

2. A method of reprogramming a field device in a process control 

2 network according to claim 1 , wherein the downloading step comprises the step of 

transmitting the programming instructions from the host device to the one of the field 
4 devices using unscheduled queued communications. 

3. A method of reprogramming a field device in a process control 

2 network according to claim 2, wherein the downloading step comprises the step of 

transmitting the programming instructions from the host device to the one of the field 
4 devices using a plurality of unscheduled queued communications. 

4. A method of reprogramming a field device in a process control 

2 network according to claim 1, wherein the one of the field devices has a first memory 
with stored program instructions and a second memory, wherein said storing step 

4 comprises the step of storing the downloaded program instructions in the second 

memory while the one of the field devices is capable of executing the stored program 

6 instructions to perform process control. 
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5. A method of reprogramming a field device in a process control 

2 network according to claim 4, wherein the causing step comprises the step of copying 
the downloaded program instructions from the second memory to the first memory. 

6. A method of reprogramming a field device in a process control 
2 network according to claim 4, wherein the causing step comprises the step of 

redirecting the one of the field devices from executing the stored program instructions 
4 in the first memory to executing the downloaded program instructions in the second 
memory. 

7. A method of reprogramming a field device in a process control 
2 network according to claim 4, wherein the causing step comprises the steps of: 

ceasing the execution of the stored program instructions in the first 
4 memory; 

copying the downloaded program instructions from the second 
6 memory to the first memory; 

initiating the execution of the downloaded program instructions in the 
8 first memory. 

8. A method of reprogramming a field device in a process control 
2 network according to claim 4, wherein the causing step comprises the steps of: 

ceasing the execution of the stored program instructions in the first 
4 memory; 

redirecting the field device to execute the downloaded program 
6 instructions in the second memory; 

initiating the execution of the downloaded program instructions in the 
8 second memory. 
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9. A method of reprogramming a field device in a process control 

2 network according to claim 1 , wherein the standard communications protocol is the 
Fieldbus protocol. 

1 0. A method of reprogramming a field device in a process control 

2 network according to claim 1 , wherein the standard communications protocol is the 
HART protocol. 

11. A system for reprogranirning a field device in a process control 
2 network having a plurality of field devices communicatively linked over a bus, 

wherein each of the field devices is capable of communicating on the bus using a 
4 standard communications protocol during operation of the process control network, 

the system comprising: 
6 a first device that generates downloadable program instructions and 

that transmits the downloadable program instructions over the bus using the 
8 standard communication protocol; and 

a second device capable of receiving the downloadable program 
1 0 instructions transmitted over the bus, the second device comprising: 

a processor adapted to execute a set of program instructions 
12 stored in the second device; 

a first memory adapted to store a first set of program 
14 instructions that may be executed by the processor; and 

a second memory adapted to store the downloadable program 
1 6 instructions transmitted over the bus; 

wherein the first device transmits the downloadable program 
1 8 instructions to the second device and the second device receives the 

downloadable program instructions and stores the program instructions in the 
20 second memory during operation of the process control network. 
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12. A system for reprogramming a field device according to claim 1 1 , 

2 wherein the standard communication protocol includes scheduled and unscheduled 

communications and the first device transmits the downloadable program instructions 
4 to the second device using unscheduled communications. 

1 3. A system for reprogramming a field device according to claim 1 1 , 

2 wherein the standard communication protocol includes concurrent analog and digital 
communications and the first device transmits the downloadable program instructions 
4 to the second device using digital communications. 

1 4. A system for reprogramming a field device according to claim 1 1 , 

2 wherein the first memory is a non- volatile memory and the second device stores the 

downloadable program instructions in the second memory while the processor is 
4 enabled to execute program instructions stored in the first memory to perform process 

control, and wherein the second device includes a transfer unit that disables the 
6 processor from executing program instructions stored in the first memory after the 

downloadable program instructions are stored in the second memory, that copies the 
8 downloadable program instructions from the second memory to the non-volatile 

memory of the first memory while the processor is disabled, and that reenables the 
10 processor to execute the downloadable program instructions stored in the first 

memory after the downloadable program instructions are copied. 

15. A system for reprogramming a field devices according to claim 11, 
2 wherein the first memory is a non-volatile memory adapted to store the downloadable 

program instructions, the second memory is a non-volatile memory adapted to store 
4 program instructions that may be executed by the processor, the second device 

includes a transfer unit adapted to store information causing the processor to execute 
6 the program instructions stored in one of the first memory and the second memory, 

and wherein the transfer unit stores the downloadable program instructions in the 
8 other of the first memory and the second memory while the processor is enabled to 

-25- 



SDOCID: <WO 0123971 A 1_l_> 



WO 01/23971 



PCTYUSOO/40619 



execute program instructions stored in the one of the first memory and the second 
1 0 memory to perform process control, disables the processor from executing program 

instructions stored in the one of the first memory and the second memory after the 
12 downloadable program instructions are stored in the other of the first memory and the 

second memory, updates the stored information to cause the processor to execute the 
1 4 downloadable program instructions stored in the other of the first memory and the 

second memory while the processor is disabled, and reenables the processor to 
16 execute the downloadable program instructions stored in the other of the first memory 

and the second memory. 

16. A system for reprogramming a field devices according to claim 1 1 , 
2 wherein the second device further comprises a non-volatile memory having a first 

portion containing the first memory, a second portion containing the second memory, 
4 the first memory and the second memory being adapted to store program instructions 

that may be executed by the processor and downloadable program instructions 
6 received in the input signal, and a transfer unit having a third memory adapted to store 
information causing the processor to execute the program instructions stored in one of 
8 the first memory and the second memory, and wherein the transfer unit stores the 

downloadable program instructions in the other of the first memory and the second 
10 memory while the processor is enabled to execute program instructions stored in the 
one of the first memory and the second memory to perform process control, disables 
12 the processor from executing program instructions stored in the one of the first 

memory and the second memory after the downloadable program instructions are 
14 stored in the other of the first memory and the second memory, updates the stored 

information in the third memory to cause the processor to execute the downloadable 
16 program instructions stored in the other of the first memory and the second memory 

while the processor is disabled, and reenables the processor to execute the 
1 8 downloadable program instructions stored in the other of the first memory and the 
second memory after the third memory is updated. 
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17. A reprogrammable field device capable of being used in a process 
2 control network having a plurality of devices communicatively coupled to a bus, 

wherein each of the devices is capable of communicating on the bus using a standard 
4 communications protocol, and wherein a host device is capable of generating input 

signals including downloadable program instructions and transmitting the input 
6 signals to the reprogrammable field device over the bus during operation of the 

process control network, the reprogrammable field device comprising: 
8 a processor adapted to execute a set of program instructions stored in 

the reprogrammable field device; 
10 a first memory adapted to store a first set of program instructions that 

may be executed by the processor; and 
12 a second memory adapted to store the downloadable program 

instructions transmitted over the bus; 
14 wherein the reprogrammable field device receives the downloadable 

program instructions and stores the downloadable program instructions in the 
1 6 second memory during operation of the process control network. 

18. A reprogrammable field device according to claim 17, wherein the 
2 standard communication protocol includes scheduled and unscheduled 

communications and the host device transmits the downloadable program instructions 
4 to the reprogrammable field device using unscheduled communications. 

19. A reprogrammable field device according to claim 1 7, wherein the 
2 standard communication protocol includes concurrent analog and digital 

communications and the host device transmits the downloadable program instructions 
4 to the reprogrammable field device using digital communications. 
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20. A reprogrammable field device according to claim 1 7, wherein the first 
2 memory is a non- volatile memory and the reprogrammable field device stores the 

downloadable program instructions in the second memory while the processor is 
4 enabled to execute program instructions stored in the first memory to perform process 

control, and wherein the reprogrammable field device further comprises a transfer 
6 unit that disables the processor from executing program instructions stored in the first 

memory after the downloadable program instructions are stored in the second 
8 memory, copies the downloadable program instructions from the second memory to 

the non-volatile memory of the first memory while the processor is disabled, and 
1 0 reenables the processor to execute the downloadable program instructions stored in 

the first memory after the downloadable program instructions are copied. 

21. A reprogrammable field device according to claim 1 7, wherein the first 
2 memory is a non-volatile memory adapted to store the downloadable program 

instructions received in the input signals, the second memory is a non-volatile 
4 memory adapted to store program instructions that may be executed by the processor, 

and the reprogrammable field device further comprises a transfer unit having a third 
6 memory adapted to store information causing the processor to execute the program 

instructions stored in one of the first memory and the second memory, and wherein 
8 the transfer unit stores the downloadable program instructions in the other of the first 

memory and the second memory while the processor is enabled to execute program 
10 instructions stored in the one of the first memory and the second memory to perform 

process control, disables the processor from executing program instructions stored in 
12 the one of the first memory and the second memory after the downloadable program 

instructions are stored in the other of the first memory and the second memory, 
14 updates the stored information in the third memory to cause the processor to execute 

the downloadable program instructions stored in the other of the first memory and the 
1 6 second memory while the processor is disabled, and reenables the processor to 

execute the downloadable program instructions stored in the other of the first memory 
1 8 and the second memory after the third memory is updated. 
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22. A reprogrammable field device according to claim 1 7, further 
2 comprising: 

a non-volatile memory having a first portion containing the first 
4 memory and a second portion containing the second memory, the first 

memory and the second memory being adapted to store program instructions 
6 that may be executed by the processor and downloadable program instructions 

received in the input signal; and 
8 a transfer unit adapted to store information causing the processor to 

execute the program instructions stored in one of the first memory and the 
10 second memory, 

wherein the transfer unit stores the downloadable program instructions 
12 in the other of the first memory and the second memory while the processor is 

enabled to execute program instructions stored in the one of the first memory 
14 and the second memory to perform process control, disables the processor 

from executing program instructions stored in the one of the first memory and 
16 the second memory after the downloadable program instructions are stored in 

the other of the first memory and the second memory, updates the stored 
1 8 information to cause the processor to execute the downloadable program 

instructions stored in the other of the first memory and the second memory 
20 while the processor is disabled, and reenables the processor to execute the 

downloadable program instructions stored in the other of the first memory and 
22 the second memory after the third memory is updated. 

23. A method of reprogramming a field device in a process control 

2 network having a plurality of devices which are communicatively linked on a bus to 

perform process control functions, the method comprising the steps of: 
4 downloading program instructions from a host device to one of the 

field devices wherein the host device divides the program instructions into a 
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plurality of data packets that are downloaded to the one of the field devices 
over time; 

reassembling the downloaded data packets into the program 

instructions in the field device; 

storing the downloaded program instructions in the field device; and 
causing the field device to execute the downloaded program 

instructions. 

24. A method of reprogramming a field device in a process control 
network according to claim 23, wherein the downloading step comprises the step of 
transmitting the data packets from the host device to the one of the field devices using 
a plurality of unscheduled queued communications. 

25. A method of reprogramming a field device in a process control 
network according to claim 23, wherein the one of the field devices has a first 
memory with stored program instructions and a second memory, wherein said storing 
step comprises the step of storing the downloaded program instructions in the second 
memory while the one of the field devices is capable of executing the stored program 
instructions to perform process control. 

26. A method of reprogramming a field device in a process control 
network according to claim 25, wherein the causing step comprises the step of 
copying the downloaded program instructions from the second memory to the first 
memory. 

27. A method of reprogramming a field device in a process control 
network according to claim 25, wherein the causing step comprises the step of 
redirecting the one of the field devices from executing the stored program instructions 
in the first memory to executing the downloaded program instructions in the second 
memory. 
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28. A method of reprogramming a field device in a process control 

2 network according to claim 25, wherein the causing step comprises the steps of: 
ceasing the execution of the stored program instructions in the first 

4 memory; 

copying the downloaded program instructions from the second 

6 memory to the first memory; 

initiating the execution of the downloaded program instructions in the 

8 first memory. 

29. A method of reprogramming a field device in a process control 

2 network according to claim 25, wherein the causing step comprises the steps of: 
ceasing the execution of the stored program instructions in the first 

4 memory; 

redirecting the field device to execute the downloaded program 

6 instructions in the second memory; 

initiating the execution of the downloaded program instructions in the 

8 second memory. 

30. A method of reprogramming a field device in a process control 

2 network according to claim 23, wherein the plurality of devices communicate using a 
standard communication protocol. 

31. A system for reprograrnming a field device in a process control 
2 network having a plurality of field devices communicatively linked over a bus, 

wherein each of the field devices is capable of communicating on the bus during 
4 operation of the process control network, the system comprising: 

a first device that divides downloadable program instructions into a 
6 plurality of data packets and that transmits the data packets over the bus; and 
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a second device capable of receiving the data packets transmitted over 
the bus and reassembling the data packets into the downloadable program 
instructions, the second device comprising: 

a processor adapted to execute a set of program instructions 
stored in the second device; 

a first memory adapted to store a first set of program 
instructions that may be executed by the processor; and 

a second memory adapted to store the downloadable program 
instructions transmitted over the bus; 

wherein the first device transmits the data packets to the second device 
and the second device receives the data packets, reassembles the data packets 
into the downloadable program instructions, and stores the program 
instructions in the second memory during operation of the process control 
network. 

32. A system for reprogramming a field device according to claim 3 1 , 
wherein the field devices communicate using scheduled and unscheduled 
communications and the first device transmits the data packets to the second device 
using unscheduled communications. 

33. A system for reprogramming a field device according to claim 3 1 , 
wherein the field devices communicate using concurrent analog and digital 
communications and the first device transmits the data packets to the second device 
using digital communications. 

34. A system for reprogramming a field device according to claim 3 1 , 
wherein the first memory is a non-volatile memory and the second device stores the 
downloadable program instructions in the second memory while the processor is 
enabled to execute program instructions stored in the first memory to perform process 
control, and wherein the second device includes a transfer unit that disables the 
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processor from executing program instructions stored in the first memory after the 
downloadable program instructions are stored in the second memory, that copies the 
downloadable program instructions from the second memory to the non-volatile 
memory of the first memory while the processor is disabled, and that reenables the 
processor to execute the downloadable program instructions stored in the first 
memory after the downloadable program instructions are copied. 

35. A system for reprogramming a field devices according to claim 3 1 , 
wherein the first memory is a non-volatile memory adapted to store the downloadable 
program instructions, the second memory is a non- volatile memory adapted to store 
program instructions that may be executed by the processor, the second device 
includes a transfer unit adapted to store information causing the processor to execute 
the program instructions stored in one of the first memory and the second memory, 
and wherein the transfer unit stores the downloadable program instructions in the 
other of the first memory and the second memory while the processor is enabled to 
execute program instructions stored in the one of the first memory and the second 
memory to perform process control, disables the processor from executing program 
instructions stored in the one of the first memory and the second memory after the 
downloadable program instructions are stored in the other of the first memory and the 
second memory, updates the stored information to cause the processor to execute the 
downloadable program instructions stored in the other of the first memory and the 
second memory while the processor is disabled, and reenables the processor to 
execute the downloadable program instructions stored in the other of the first memory 
and the second memory. 

36. A system for reprograrnming a field devices according to claim 3 1 , 
wherein the second device further comprises a non-volatile memory having a first 
portion containing the first memory, a second portion containing the second memory, 
the first memory and the second memory being adapted to store program instructions 
that may be executed by the processor and downloadable program instructions 

-33 - 



0123971 A 1J_> 



WO 01/23971 



PCT/US00/40619 



6 received in the input signal, and a transfer unit having a third memory adapted to store 

information causing the processor to execute the program instructions stored in one of 
8 the first memory and the second memory, and wherein the transfer unit stores the 

downloadable program instructions in the other of the first memory and the second 
10 memory while the processor is enabled to execute program instructions stored in the 

one of the first memory and the second memory to perform process control, disables 
1 2 the processor from executing program instructions stored in the one of the first 

memory and the second memory after the downloadable program instructions are 
14 stored in the other of the first memory and the second memory, updates the stored 

information in the third memory to cause the processor to execute the downloadable 
1 6 program instructions stored in the other of the first memory and the second memory 

while the processor is disabled, and reenables the processor to execute the 
18 downloadable program instructions stored in the other of the first memory and the 

second memory after the third memory is updated. 
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